Skip to main content
Version: Next

Reference Implementations

Developed alongside the OpenDI standards, these open source projects demonstrate OpenDI compliance with fully-functional example implementations.

These projects are currently under active development, but prototypes and source code are available. We encourage you to check these projects out! Contribute code or feedback, make forks or extensions, submit issues, break things!

CDD Authoring Tool

Try it out >>

CDD Authoring Tool Preview

This tool allows you to construct OpenDI standards-compliant Causal Decision Diagrams in your browser. It offers a graphical view using the JointJS graphing library, and a JSON view using the svelte-jsoneditor project.

This project aims to demonstrate a working use case for the OpenDI JSON Schema. The JSON editor view dynamically mirrors changes and selections from the graphical view, and vice versa, allowing you to interactively explore and manipulate the structure of a Causal Decision Model's JSON data.

Contributors

Simple Model API (Go)

Browse the repo >>

Model API Preview

This repository provides a working example implementation of the OpenDI API Specification. Written in Go, this implementation provides straightforward examples of type definitions, endpoint implementations, and ORM/database integration. The API uses Gin and GORM.

Disclaimer

This is not a commercial API!

This API is a functional reference example. It is not intended to be a commercially-viable solution. This API was not constructed with careful consideration for scalability, security, user authentication, etc.

Contributors

Docker Compose Authoring Tool

Get started >>

Authoring Tool Compose Preview

Alongside the CDD Authoring Tool frontend and the Simple Model API, we've created Docker Compose files and configurations that combine these projects, allowing you to host a local version of the Authoring Tool complete with API integration for saving and loading multiple Causal Decision Models from a simple SQL database.

The Compose project creates 3-4 Docker services:

  • Go API
  • SQL database (or volume for SQLite)
  • Apache frontend server (hosts web tool frontend)
  • Nginx server for reverse proxy

See the README for instructions on setting up a local deployment.

The component projects can also be deployed individually. The Authoring Tool is configurable for use with any OpenDI-compliant API, and the API can be deployed separately.

Contributors